block模板的分块替换

比如布局模板\template\index_style\default\index\layout.htm中每个区块由{block} {/block}标签组成。 下面就是基础模板中的一个典型的区块设计(用于设计网站标题):

{block name="title"}

网站标题

{/block}

block标签必须指定name属性来标识当前区块的名称,这个标识在当前模板中应该是唯一的,block标签中可以包含任何模板内容,包括其他标签和变量,例如:

{block name="head_title"}{$webdb.seo_title}{/block}

你甚至还可以在区块中加载外部文件:

{block name="body_Footcont"}

{include file="index@footmenu" /}

{/block}

一个模板中可以定义任意多个名称标识不重复的区块,例如下面定义了一个base.html基础模板:

{block name="title"}标题{/block}

{block name="menu"}菜单{/block} {block name="left"}左边分栏{/block} {block name="main"}主内容{/block} {block name="right"}右边分栏{/block} {block name="footer"}底部{/block} 然后我们在子模板(其实是当前操作的入口模板)中使用继承: {extend name="$index_style_layout" /}

{block name="title"}{$title}{/block}

{block name="menu"}

首页

资讯

论坛

{/block}

{block name="left"}{/block}

{block name="main"}

{volist name="list" id="vo"}

{$vo.title}

{$vo.content}

{/volist}

{/block}

{block name="right"}

最新资讯:

{volist name="news" id="new"}

{$new.title}

{/volist}

{/block}

{block name="footer"}

{block}]@ThinkPHP 版权所有

{/block}

上例中,我们可以看到在子模板中使用了extend标签来继承了母模板$index_style_layout。

在子模板中,可以对基础模板中的区块进行重载定义,如果没有重新定义的话,则表示沿用基础模板中的区块定义,如果定义了一个空的区块,则表示删除基础模板中的该区块内容。 上面的例子,我们就把left区块的内容删除了,其他的区块都进行了重载。而

特别注意:

{block name="footer"}

{block}@ThinkPHP 版权所有

{/block}

这一区块中有{block}这个标签,当区块中有这个标记时,就不只是直接重载这个区块,它表示引用所继承模板对应区块的内容到这个位置,最终这个区块是合并后的内容。所以这里footer区块最后的内容是: 底部@ThinkPHP 版权所有

extend标签的用法和include标签一样,你也可以加载其他模板:

{extend name="$index_style_layout" /}

或者使用绝对文件路径加载

{extend name="./Template/Public/base.html" /}

再特别注意:

在当前子模板中,只能定义区块。而不能在区块外面定义其他的模板内容,否则将会直接忽略,并且只能定义基础模板中已经定义的区块。

重要的事再重复一次,并且只能定义基础模板中已经定义的区块。

例如,如果采用下面的定义:

{block name="title"}

{$title}

{/block}

首页

资讯

论坛

下面的三个链接导航部分将是无效的,不会显示在模板中。因为他在区块的外面。

子模板中的区块定义顺序是随意的,模板继承的用法关键在于基础模板如何布局和设计规划了,如果结合原来的布局功能,则会更加灵活。

下面这个极少用, 大家可以了解一下即可

模板可以多级继承,比如B继承了A,而C又继承了B,最终C中的区块会覆盖B和A中的同名区块,但C和B中的区块必须是A中已定义过的。比如布局模板\template\index_style\default\index\layout.htm中每个区块由{block} {/block}标签组成。 下面就是基础模板中的一个典型的区块设计(用于设计网站标题):

  1. {block name="title"}<title>网站标题</title>{/block}

block标签必须指定name属性来标识当前区块的名称,这个标识在当前模板中应该是唯一的,block标签中可以包含任何模板内容,包括其他标签和变量,例如:

  1. {block name="head_title"}{$webdb.seo_title}{/block}

你甚至还可以在区块中加载外部文件:

  1. {block name="body_Footcont"}
  2. {include file="index@footmenu" /}
  3. {/block}

一个模板中可以定义任意多个名称标识不重复的区块,例如下面定义了一个base.html基础模板:

  1. <html>
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  4. <title>{block name="title"}标题{/block}</title>
  5. </head>
  6. <body>
  7. {block name="menu"}菜单{/block}
  8. {block name="left"}左边分栏{/block}
  9. {block name="main"}主内容{/block}
  10. {block name="right"}右边分栏{/block}
  11. {block name="footer"}底部{/block}
  12. </body>
  13. </html>

然后我们在子模板(其实是当前操作的入口模板)中使用继承:

  1. {extend name="$index_style_layout" /}
  2. {block name="title"}{$title}{/block}
  3. {block name="menu"}
  4. <a href="/" >首页</a>
  5. <a href="/info/" >资讯</a>
  6. <a href="/bbs/" >论坛</a>
  7. {/block}
  8. {block name="left"}{/block}
  9. {block name="main"}
  10. {volist name="list" id="vo"}
  11. <a href="/new/{$vo.id}">{$vo.title}</a><br/>
  12. {$vo.content}
  13. {/volist}
  14. {/block}
  15. {block name="right"}
  16. 最新资讯:
  17. {volist name="news" id="new"}
  18. <a href="/new/{$new.id}">{$new.title}</a><br/>
  19. {/volist}
  20. {/block}
  21. {block name="footer"}
  22. {__block__}]@ThinkPHP 版权所有
  23. {/block}

上例中,我们可以看到在子模板中使用了extend标签来继承了母模板$index_style_layout

在子模板中,可以对基础模板中的区块进行重载定义,如果没有重新定义的话,则表示沿用基础模板中的区块定义,如果定义了一个空的区块,则表示删除基础模板中的该区块内容。 上面的例子,我们就把left区块的内容删除了,其他的区块都进行了重载。而


特别注意:

  1. {block name="footer"}
  2. {__block__}@ThinkPHP 版权所有
  3. {/block}

这一区块中有{block}这个标签,当区块中有这个标记时,就不只是直接重载这个区块,它表示引用所继承模板对应区块的内容到这个位置,最终这个区块是合并后的内容。所以这里footer区块最后的内容是: 底部@ThinkPHP 版权所有

extend标签的用法和include标签一样,你也可以加载其他模板:

  1. {extend name="$index_style_layout" /}

或者使用绝对文件路径加载

  1. {extend name="./Template/Public/base.html" /}

再特别注意:


在当前子模板中,只能定义区块。而不能在区块外面定义其他的模板内容,否则将会直接忽略,并且只能定义基础模板中已经定义的区块。

重要的事再重复一次,并且只能定义基础模板中已经定义的区块。

例如,如果采用下面的定义:

  1. {block name="title"}<title>{$title}</title>{/block}
  2. <a href="/" >首页</a>
  3. <a href="/info/" >资讯</a>
  4. <a href="/bbs/" >论坛</a>

下面的三个链接导航部分将是无效的,不会显示在模板中。因为他在区块的外面。

子模板中的区块定义顺序是随意的,模板继承的用法关键在于基础模板如何布局和设计规划了,如果结合原来的布局功能,则会更加灵活。

下面这个极少用, 大家可以了解一下即可

模板可以多级继承,比如B继承了A,而C又继承了B,最终C中的区块会覆盖B和A中的同名区块,但C和B中的区块必须是A中已定义过的。